
/*
**
** Copyright 2020 OpenHW Group
**
** Licensed under the Solderpad Hardware Licence, Version 2.0 (the "License");
** you may not use this file except in compliance with the License.
** You may obtain a copy of the License at
**
**     https://solderpad.org/licenses/
**
** Unless required by applicable law or agreed to in writing, software
** distributed under the License is distributed on an "AS IS" BASIS,
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
** See the License for the specific language governing permissions and
** limitations under the License.
**
*******************************************************************************
** Debugger code
*******************************************************************************
*/

#include "corev_uvmt.h"

.section .debugger, "ax"
.global _debugger_start
.set test_fail, 0x1
.set test_debugger_ok, 0xa5

_debugger_start:
    // No code should have been run before this
    // check dpc == boot_addr == 0x80
    csrr t1, dpc
    li t2, 0x80 # Boot addr
    bne t1, t2, _debugger_error

    // Write known value to memory@0x1000
    // We don't have any globals or pointers
    // at this time, so we must rely on
    // memory (hopefully) not being used
    la a0, test_debugger_entry
    li t0, test_debugger_ok
    sw t0, 0(a0)
    dret

_debugger_error:
    li a0, CV_VP_STATUS_FLAGS_BASE
    li t0, test_fail
    sw t0, 0(a0)
    dret

.section .data
.global test_debugger_entry
test_debugger_entry:
    .word 0
